<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>文章列表</title>
  <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
  <link rel="stylesheet" href="./css/reset.css">
  <link rel="stylesheet" href="./css/iconfont.css">
  <link rel="stylesheet" href="./css/main.css">
  <script src="./libs/jquery-1.12.4.min.js"></script>
  <!-- 引入模板引擎js文件 -->
  <script src="./libs/template-web.js"></script>

  <!-- 引入分页插件 -->
  <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
  <div class="container-fluid">
    <div class="common_title">
      文章列表
    </div>
    <div class="container-fluid common_con">
      <div class="row opt_btns">
        <div class="col-xs-6">
          <form class="form-inline">
            <select id="selCategory" name="" class="form-control input-sm">
              <option value="">所有分类</option>
              <option>未分类</option>
              <option>奇趣事</option>
              <option>会生活</option>
              <option>爱旅行</option>
            </select>
            <select id="selStatus" name="" class="form-control input-sm">
              <option value="">所有状态</option>
              <option value="草稿">草稿</option>
              <option value="已发布">已发布</option>
            </select>
            <!-- <button id="btnSearch" class="btn btn-default btn-sm">筛选</button> -->
          </form>
        </div>
        <div class="col-xs-6">
          <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
        </div>
      </div>
      <table class="table table-striped table-bordered table-hover mp20">
        <thead>
          <tr>
            <th>标题</th>
            <th>作者</th>
            <th>分类</th>
            <th class="text-center">发表时间</th>
            <th class="text-center">状态</th>
            <th class="text-center" width="100">操作</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td>王积千造统最头</td>
            <td>杰克</td>
            <td>奇趣事</td>
            <td class="text-center">2017-06-08 07:08:46</td>
            <td class="text-center">已发布</td>
            <td class="text-center">
              <a href="article_edit.html" class="btn btn-default btn-xs">编辑</a>
              <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
            </td>
          </tr>
        </tbody>
      </table>
      <div class="row text-center">
        <ul id="pagination" class="pagination-sm"></ul>
      </div>
    </div>
  </div>
</body>

</html>
<!-- 下拉列表渲染 -->
<script type="text/html" id="tpl_sel">
  <option value="">所有分类</option>
  {{each}}
  <option value="{{$value.id}}">{{$value.name}}</option>
  {{/each}}
<!-- <option value="">所有分类</option>
{{each}}
<option value="{{$value.id}}">{{$value.name}}</option>
{{/each}} -->
</script>

<!-- 文章列表的渲染 -->
<script type="text/html" id="tpl_list">

  {{each}}
  <tr>
    <td>{{$value.title}}</td>
    <td>{{$value.author}}</td>
    <td>{{$value.category}}</td>
    <td class="text-center">{{$value.date}}</td>
    <td class="text-center">{{$value.state}}</td>
    <td class="text-center">
      <a href="article_edit.html?articleId={{$value.id}}" dataid="{{$value.id}}" class="btn btn-default btn-xs">编辑</a>
      <a href="javascript:void(0);" dataid="{{$value.id}}" class="btn btn-danger btn-xs delete">删除</a>
    </td>
  </tr>
  {{/each}}
  <!-- {{each}}
<tr>
  <td>{{$value.title}}</td>
  <td>{{$value.author}}</td>
  <td>{{$value.category}}</td>
  <td class="text-center">{{$value.date}}</td>
  <td class="text-center">{{$value.state}}</td>
  <td class="text-center">
    <a href="article_edit.html" dataid="{{$value.id}}" class="btn btn-default btn-xs">编辑</a>
    <a href="javascript:void(0);" dataid="{{$value.id}}" class="btn btn-danger btn-xs delete">删除</a>
  </td>
</tr>
{{/each}} -->

</script>

<script>
  //#region 
  $(function () {
    // http://localhost:8080/api/v1

    // 获取文章类别，准备渲染下拉菜单
    $.ajax({
      url: 'http://localhost:8080/api/v1/admin/category/list',
      success(res) {
        if (res.code === 200) $('#selCategory').html(template('tpl_sel', res.data))  // 渲染下拉框
      }
    })

    // 全局变量selPage
    let selPage = 1

    // 封装加载数据函数
    function loadData(page) {
      $.ajax({
        url: 'http://localhost:8080/api/v1/admin/article/query',
        data: {
          type: $('#selCategory').val(), // 文章类型 为空返回所有
          state: $('#selStatus').val(),// 文章状态 为空返回所有
          page,// 返回页数
          perpage: 3// 每个页数多少条数据
        },
        success(res) {
          if (res.code === 200) {
            const { data: { data } } = res // 解构赋值data
            $('tbody').html(template('tpl_list', data))


            // 分页器
            if (res.data.totalCount == 0) {
              $('tbody').empty()
              $('#pagination').html('<img src="../images/空空如也.jpg" alt="">')
            } else {
              // 清除分页导航,之后再执行分页导航配置
              $('#pagination').twbsPagination('destroy')

              // 分页导航配置
              $('#pagination').twbsPagination({
                // 总共页数
                totalPages: res.data.totalPage,

                // 可见页数
                visiblePages: 7,

                // 启动时的页数
                startPage: page,

                // 防止递归
                initiateStartPageClick: false,

                first: '首页',
                last: '尾页',
                next: '下一页',
                prev: '上一页',

                // 点击时的回调函数 
                onPageClick(event, page) {
                  // 将page赋值给全局变量selPage
                  selPage = page
                  // 将点击的回调函数的page项,传个loadData
                  loadData(page)
                }
              });
            }
          }
        }
      })
    }
    // 初始化页面列表
    loadData(1)

    // 筛选按钮
    // $('#btnSearch').on('click', function (e) {
    //   e.preventDefault()

    //   loadData(1)
    // })


    // 删除按钮,事件委托
    $('tbody').on('click', '.delete', function (e) {
      e.preventDefault()
      const id = $(this).attr('dataid')
      $.ajax({
        method: 'post',
        url: 'http://localhost:8080/api/v1/admin/article/delete',
        data: { id },
        success(res) {
          if (res.code === 204) {
            // 当我删除最后一页最后一条时，判断tr的长度。如果为0，则跳到前一页
            // 当删除第一页最后一条时，增加selpage判断，使其加载第一页并且没有数据的函数
            if ($('tbody tr').length > 1 || selPage == 1) {
              loadData(selPage)
            } else {
              loadData(--selPage)
            }
          }
        }
      })
    })

    $('select').on('change', function () {
      loadData(1)
    })
  })


  //#endregion

  //#region 
  // $(function () {
  //   // /admin/category/list
  //   $.ajax({
  //     url: 'http://localhost:8080/api/v1/admin/category/list',
  //     success(res) {
  //       if (res.code === 200) $('#selCategory').html(template('tpl_sel', res.data))

  //     }
  //   })
  //   // 设置全局变量,控制分页器
  //   let selPage = 1
  //   // 封装函数获取文章数据
  //   function loadData(page) {
  //     $.ajax({
  //       url: 'http://localhost:8080/api/v1/admin/article/query',
  //       data: {
  //         key: '',
  //         type: $('#selCategory').val(),
  //         state: $('#selStatus').val(),
  //         page,
  //         perpage: 6
  //       },
  //       success(res) {
  //         if (res.code == 200) {
  //           // 获取数据,渲染页面,模板引擎
  //           const { data: { data } } = res
  //           $('tbody').html(template('tpl_list', data))

  //           if (res.data.totalPage == 0) {
  //             $('tbody').empty()
  //             $('#pagination').twbsPagination('destroy')
  //             $('#pagination').html('没有数据啦,记得添加噢...')

  //           } else {
  //             // 分页器
  //             // 每次进入函数时销毁掉分页器,重新配置.防止页码错误
  //             $('#pagination').twbsPagination('destroy');

  //             // 配置分页器
  //             $('#pagination').twbsPagination({
  //               // 最大显示多少页
  //               visiblePages: 7,
  //               // 插件初始化时在开始页面取消触发点击
  //               initiateStartPageClick: false,
  //               // 总页数参数
  //               totalPages: res.data.totalPage,
  //               first: '首页',
  //               prev: '上一页',
  //               next: '下一页',
  //               last: '尾页',
  //               // 启动时的页数
  //               startPage: selPage,
  //               onPageClick(event, page) {
  //                 // 将page赋值给selPage
  //                 selPage = page
  //                 loadData(page)
  //               }
  //             })
  //           }

  //         }
  //       }
  //     })
  //   }
  //   // 初始加载页面时获取数据
  //   loadData()

  //   $('#btnSearch').on('click', function (e) {
  //     e.preventDefault()
  //     loadData()
  //   })

  //   // 删除功能
  //   $('tbody').on('click', '.delete', function (e) {
  //     e.preventDefault()
  //     let id = $(this).attr('dataid')
  //     // /admin/category/delete
  //     if (confirm('是否删除...')) {
  //       $.ajax({
  //         method: 'post',
  //         url: 'http://localhost:8080/api/v1/admin/article/delete',
  //         data: { id },
  //         success(res) {
  //           alert(res.msg)
  //           if (res.code === 204) {
  //             if ($('tbody tr').length > 1 || selPage == 1) {
  //               loadData(selPage)
  //             } else {
  //               loadData(--selPage)
  //             }
  //           }
  //         }
  //       })
  //     }
  //   })
  // })
  //#endregion
</script>